## CO503: Lab 3 - Multi-Processor System-on-Chip (MPSoC) Design

In this lab, you will use FPGA design tools to create your first Multi-Processor System-on-Chip. A common method to share data between two processors is via shared memory. In Part 1, you will design a simple producer-consumer MPSoC with communication via shared memory. In Part 2 of the lab, you will change the communication method to a dedicated hardware FIFO which can achieve better performance.

## Part 1: Producer-Consumer Applications on a Shared Memory Multi-Processor

You will be designing an MPSoC in Qsys with two processor cores. Create a new Qsys system with two Nios II processors, *cpuo* and *cpu1*.

- Each CPU must use its own TIMER and JTAG UART
- Each CPU must use its own ON-CHIP MEMORY device as the instruction memory
- Both CPUs must share a separate ON-CHIP MEMORY device as the data memory

You can use a 50MHz clock signal to drive all components within the Qsys system. Discuss how the available data memory can be partitioned between the two CPUs. There should be memory partitions private for each CPU, and one partition shared between the two CPUs for communication. Decide on a partitioning scheme before proceeding.

Once the hardware is complete, create two software projects, one for each CPU. One project will run the producer application, while the other runs the consumer. You will need to modify the "Linker Script" in the BSP editor for both producer and consumer applications, in order implement the previously decided memory partitioning.

Study the provided code for sample producer and consumer applications. You are also given a skeleton code which implements a software FIFO queue, study it first and complete it to place the software FIFO queue in the shared data memory partition. Alternatively, you may write your own software FIFO queue, however it must be implemented within the shared data memory partition.

Get your work checked when complete.

## Part 2: Hardware FIFOs

Create a system similar to the one in Part 1, but with the software FIFO replaced with a dedicated hardware on-chip FIFO memory in Qsys. Producer and consumer applications running on the two processors should use the hardware FIFO for communication, instead of the previous software method. Refer to the provided datasheet about using the on-chip FIFO memory component.

Get your work checked when complete.